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Comment défile un arrière-plan 
Du Légo au logo 


Les petits Sharp 


Micro : des livres à lire 


Page manquante 
(publicité et colophon) 


Comment ca va? 


Comment fonctionne un système de communication mettant en 
œuvre un micro-ordinateur et un modem? Qu'est-ce qu’un « duplex »? 
C’est ce que nous nous proposons de vous expliquer. 


en minusCuIes ?. ; 
ce 


4, 
> 
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tre ser° 


:çire EN Minustuees ; 
écn PUSCUIeS 7... Votre terminal P 


Minuscuies ?. s 


Un système « duplex » a la particularité de per- 
mettre la transmission et la réception simultanées 
des données. Ce n’est pas toujours le cas pour 
tous les modèles. 

Il est possible, de ce point de vue, de faire une 
comparaison avec le téléphone, où les deux inter- 
locuteurs peuvent parler en même temps, et avec 
une radio Citizen Band, où l’on ne peut, selon 
les cas, qu’émettre ou recevoir un message à la 
fois. 

Le principal avantage d’une transmission bidi- 
rectionnelle simultanée est qu’il permet de gagner 
du temps. Si votre correspondant vous transmet 
un très long menu et que vous avez déjà choisi 
l’option 1, vous n’aurez qu’à appuyer sur la tou- 
che 1, et le système en tiendra compte aussitôt, 
alors qu’en transmission bidirectionnelle alterna- 
tive il vous faudrait attendre que le programme 
soit chargé en mémoire. 

La méthode de base est très simple : chaque 
ordinateur dispose d’une fréquence qui lui est 
propre. Celui qui appelle a la fréquence « ori- 
gine », celui qui reçoit a la fréquence « de 
réponse ». Et, en toute logique, quand un ordi- 
nateur transmet des données par l’intermédiaire 
des lignes téléphoniques, il doit bien sûr savoir 


quel sera son interlocuteur à l’autre bout du fil. 
Ce peut être aussi bien un Spectrum qu’un 
Télétype à 132 colonnes; selon les cas, il dispo- 
sera, ou non, de la couleur, il acceptera, ou non, 
les lettres minuscules : car il peut s’agir d’un 
très gros système ou d’un simple ordinateur 
domestique. 


Protocoles d'accord 


On peut traiter le problème de trois façons 
différentes. 

La première est typique de BASICODE, qui ne 
transmet que les informations accessibles aux ter- 
minaux les moins bien équipés; c’est ce qu’on 
pourrait appeler la méthode du « plus petit com- 
mun dénominateur ». 

La deuxième consiste à s’adapter aux possibi- 
lités du terminal, et à modifier en conséquence 
la transmission des données. 

La troisième consiste à émettre suivant un for- 
mat à valeur générale; c’est à l’utilisateur de tirer 
parti des informations reçues, grâce à un logiciel 
spécialisé. 

De ces trois procédés, le premier reste le moins 
employé : le Télétype est en effet le plus courant 


Il n’y a pas d’abonné... 


On voit parfois, dans les 
publicités, des ordinateurs 
portables et des modems 


acoustiques, alimentés 


par 


piles, mis en œuvre dans 


les conditions les plus 
difficiles. Mais il est 
parfois totalement 
impossible de s'en serv 
c'est le cas avec les 
cabines téléphoniques, 


jrs 


les standards à commande 
manuelle (encore en usage 


dans de nombreux hôte 


IS), 


ainsi qu'avec des lignes 


saturées d'électricité 
statique — ce qui n’est 
pas rare dans certaines 


régions un peu à l'écart. 


(CI. Steve Cross.) 
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Observer les règles : 

Il existe trois grandes 
façons de régler les 
protocoles de 
communication. 

La première est celle 

du « plus petit commun 
dénominateur ». La 
deuxième consiste à 
modifier les émissions de 
l'ordinateur émetteur de 
sorte qu'elles puissent être 
accessibles à des 
terminaux très différents. 
La troisième oblige le 
terminal à se comporter 
« comme si » il était un 
terminal bien spécifique : 
il doit donc être équipé 
d'un logiciel dit 

d'« émulation ». 


des terminaux. Or il ne dispose que des majus- 
cules, n’a ni couleur, ni graphisme, ni formatage 
d’impression, et sa vitesse demeure réduite. La 
deuxième méthode est la plus commune — c’est 
par exemple celle de presque tous les réseaux 
d'utilisateurs. 

La troisième est essentiellement réservée aux 
réseaux commerciaux ou universitaires, et fait 
usage d’une technique de programmation qu’on 
appelle « émulation de terminal ». 

Comme le nom l’indique, il s’agit simplement 
d’amener l’ordinateur à se comporter comme un 
terminal spécifique. 

Un logiciel spécialisé traduit tous les caractè- 
res de contrôle (effaçage d’écran, positionnement 
du curseur) de façon qu’ils soient compréhensi- 
bles pour l’appareil récepteur. Bien sûr le pro- 


Protocole de transmission unique 


L'ordinateur 
émetteur transmet 
ses messages de 
façon qu'ils soient 
adaptés aux 


terminaux les plus 
simplifiés. Tous 
recevront donc le 
même texte, quel 
que soit leur degré 
de sophistication. 


Protocole de transmission multiple 


Émulation de terminal 


Certains systèmes 
exigent un type de 
terminal bien 


Kevin Jones 


spécifique. Si le vôtre 
est d'un modèle différent, 
vous aurez besoin d'un 
logiciel capable de 
convertir à la fois les 
entrées et les sorties, 
afin de reproduire les 
caractéristiques 
exigées. 
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ms 
LLELLELEE 


L'ordinateur 
émetteur s'adapte 
à chaque terminal 
particulier. Un 
Spectrum recevra 
donc un message 


> 


€ _— 


sur 32 colonnes, 
tandis qu'un BBC 
Micro bénéficiera 
d'un texte de 
colonnes en mode 0. 


cédé fonctionne aussi dans l’autre sens. C’est 
généralement le code de caractères ASCII qui sert 
de référence. Certains caractères ont une impor- 
tance toute particulière : ASCII 19 (« XOFF », 
obtenu par Control-S) interrompt provisoirement 
la transmission des données, ASCII 17 (« XON », 
obtenu par Control-Q) la remet en marche, 
ASCII 10 (« LF », obtenu par Control-J) pro- 
voque l'impression d’une ligne sans retour 
chariot, et ASCII 7 (« BEL », obtenu par 
Control-G) génère un bip sonore, ce qui est très 
utile si vous voulez attirer l’attention de votre 
correspondant. 


Le protocole XModem 


Voyons maintenant comment les logiciels eux- 
mêmes sont transmis. S’ils sont en BASIC, cela 
ne présente pas de grosses difficultés. 

La plupart des micro-ordinateurs sont capables 
de « détokéniser » les programmes (ce terme bar- 
bare signifie simplement : de les retraduire au for- 
mat ASCII à partir de leur forme compactée). 
Sur le BBC Micro, il faut faire ‘SPOOL, sur le 
Commodore 64, LIST, sur le Tandy, CSAVE, nom du 
programme, À. Les données sont alors transmises, 
transcrites, puis de nouveau compactées en 
mémoire. 

Le système d’exploitation CP/M fait malheu- 
reusement usage de certains fichiers (de type 
COM) qui ne peuvent être traduits en code 
ASCII. Il faut donc recourir à un protocole par- 
ticulier, dit XModem. 

Ce logiciel lit sur disquette un fichier CP/M 
et le transmet sous forme binaire classique. Natu- 
rellement, les deux correspondants doivent en 
être équipés. 

Nous verrons ultérieurement les multiples res- 
sources de la télécommunication informatique. 
Bornons-nous pour le moment à signaler les pos- 
sibilités offertes par un modem. 

On appelle courrier électronique l’échange de 
messages entre usagers, par l’intermédiaire d’un 
gros système qui les garde en mémoire jusqu’à 
ce qu’ils soient lus par leur destinataire. Le Mini- 
tel français en est un bon exemple. 

Toutefois, les passionnés d’informatique cher- 
chent surtout à échanger des programmes par 
téléphone. Un logiciel en BASIC, nous l’avons vu, 
ne pose aucun problème de transmission : le pro- 
cédé est simple, rapide et beaucoup plus prati- 
que que des envois par la poste. Vous pourrez 
même demander conseil à des amis en leur fai- 
sant parvenir ce programme génial que vous êtes 
en train d’écrire, mais qui s’obstine à ne pas 
tourner ! 

Un autre usage, encore au stade embryonnaire 
en France, est celui des réseaux d’usagers. Les 
possibilités sont très vastes : échange de tuyaux, 
demande de renseignements, participation à des 
jeux d’aventures, réception de programmes, etc. 
Ce phénomène a pris une très grande ampleur aux 
Etats-Unis, où de très nombreux particuliers ont 
monté leur propre réseau, auquel on peut accé- 
der gratuitement, ou presque (mais il faut tou- 
jours payer les notes de téléphone!). 


Nous avons vu comment connecter un servomoteur à un port 
utilisateur via le système tampon mis au point précédemment. 
Voici comment commander plusieurs servomoteurs simultanément. 


Il y a huit lignes de données qui peuvent être 
connectées à des moteurs, bien que seules qua- 
tre de celles-ci puissent être utilisées par le bof- 
tier tampon que nous avons conçu. Il serait pos- 
sible d’utiliser les huit lignes en reproduisant les 
circuits du boîtier tampon pour les quatre autres 
lignes. Pour commander huit moteurs simulta- 
nément, l’algorithme que nous avons mis au 
point précédemment pour un seul moteur doit 
être légèrement modifié. Les impulsions commen- 
cent toutes au même moment mais la seconde 
boucle de temporisation est remplacée par une 
table de référence. 255 adresses de mémoire sont 
réservées à la table et sont toutes mises à 
255 ($FF) initialement. 

Les exceptions — lorsqu’un moteur est mis 
hors tension — sont alors entrées dans cette table. 
Par exemple, si la ligne de données 2 doit être 
mise hors tension après un compte de 20, la ving- 
tième entrée de la table passera de la valeur 
binaire 11111111 ($FF) à la valeur binaire 
11111011 ($FB). 

Notez que dans le listage d'assemblage cela est 
fait par l’opérateur AND agissant sur la valeur 
déjà placée dans la table. Dès que les huit excep- 


tions ont été entrées dans la table, la boucle 
d’attente est exécutée, mais cette fois chaque élé- 
ment de la table est associé au port utilisateur au 
moyen de l’opérateur AND. 

Voici l’algorithme pour la commande de 
moteurs multiples : 
1. Spécifier l’angle de chaque moteur en 
stockant les angles dans huit octets (de ANGLE + 0 
à ANGLE + 7). 
2. Mettre tous les bits de données du port utili- 
sateur au niveau élevé pour démarrer simultané- 
ment les impulsions. 
3. Insérer les exceptions dans la table de 
référence. 
4. Attendre 1/1 000 de seconde. 
5. Charger la valeur binaire 11111111 ($FF) dans 
laccumulateur. Associer à tour de rôle l’accu- 
mulateur avec chaque élément de la table de réfé- 
rence au moyen de l’opérateur AND. Lorsqu’une 
exception est rencontrée, le bit approprié est mis 
à zéro. Puisque l’opération AND se poursuit 
jusqu’à la fin de la table, ce bit demeurera à zéro 
jusqu’à la fin. 
6. Remettre les exceptions de la table à la valeur 
binaire 11111111, pour la prochaine impulsion. 


Le servomoteur 2 commande 
le mouvement avant-arrière 


Ressorts 


Manche à balai 


Pièces en U 


Le servomoteur 1 commande 
le mouvement gauche-droite 


Réaction 

du manche à balai 

Les manches à balai sont 
normalement utilisés pour 
fournir une information 
directionnelle utilisée par 
logiciel. Il est possible 
d'utiliser des servomoteurs 
pour permettre au logiciel 
de commande de renvoyer 
une information au manche 
à balai. Deux servomoteurs 
sont utilisés pour pousser 
et pour tirer le manche 
dans chaque plan 
horizontal; ils fournissent 
ainsi d'importantes 
données de réaction dans 
certains simulateurs de vol 
évolués. Le fait que le 
manche à balai réagisse 
dans la main en réponse 

à un mouvement de 
commande du pilote 
améliore la simulation en 
donnant à l'utilisateur une 
information tactile en plus 
des données visuelles. 

(CI. Kevin Jones.) 
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Traceur 

Il est possible de concevoir 
un traceur en utilisant un 
servomoteur pour déplacer 
le stylo, tandis qu'un 
moteur pas à pas entraîne 
le papier sous le stylo. 

Les mouvements 
angulaires de l’axe de 
rotation du servomoteur 
sont traduits en des 
mouvements linéaires du 
stylo au moyen d’une 
bande d'entraînement. 

Le mouvement du stylo 
correspond aux 
changements de la variable 
de l'axe vertical — par 
exemple, la température ou 
la pression barométrique 
— tandis que le 
mouvement continu du 
papier correspond souvent 
au temps écoulé. 

(CI. Kevin Jones.) 


Axe esclave 


Un moteur pas à pas 
entraine le papier au 
moyen d'un dispositif 
à traction ou à friction 


Rouleau de papier 
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Mécanisme de direction 


Re 


Servomoteur 


Roue 


Tige de connexion 


Les listages donnés pour le BBC Micro ont la 
même routine initiale (lignes 10 à 280) dans les 
deux programmes. Le premier listage concerne 
la commande d’un seul servomoteur connecté à 
l’une des lignes du port utilisateur. Le chrono- 
métreur d'événements est mis en place à l’aide 
de BASIC. Une procédure d’initialisation assem- 
ble la routine de gestion d’événements avant que 
le programme principal ne l’exécute en autorisant 
l’événement 5. 

Sur le BBC Micro, le système d’exploitation 
comporte un chronomètre utilisateur au centième 
de secondes. En le mettant à 2/100 de seconde 
et en utilisant le vecteur d'événements, le proces- 
seur passera au code d’émission d’impulsions au 
bon moment. Puisque le système d’exploitation 
fut conçu pour utiliser les événements, le pro- 
gramme n’a qu’à sortir du sous-programme 
(RTS) et n'utilise pas RTI. 

Le second listage, pour la commande de plu- 
sieurs servomoteurs, utilise d’abord une boucle 
BASIC pour initialiser la table de référence avec 
des valeurs $FF. Si chaque élément de la table 
était envoyé à tour de rôle au port utilisateur, tou- 
tes les impulsions se poursuivraient pendant 
2/1 000 de seconde. Il est possible de créer des 
exceptions, et chaque moteur peut être mis hors 
tension à tour de rôle. Les exceptions sont 

insérées dans la table en commençant par le 
moteur 7, en utilisant un décalage (dans le regis- 


Un servomoteur 
commande 
la position du stylo 


Bande d'entrainement 


Dans notre robot 
d'atelier, la commande 
directionnelle est assurée 
Par le contrôle individuel 
de deux moteurs pas à 
Pas bidirectionnels. 
Le diagramme présente 
un Servomoteur monté 
directement au-dessus de 
l'axe : il pousse et tire 
les tiges connectées aux 
roues pour diriger le 
véhicule. || serait encore 
possible d'utiliser un 
mécanisme à Support et 
à pignon, en montant 
l'engrenage du pignon 
Sur l’axe de rotation 
du servomoteur. 


Pivot ou joint universel 


tre X) proportionnel à la longueur de l’impul- 
sion. Puis la table est envoyée au port utilisateur 
en adressant chaque élément indirectement, en 
utilisant cette fois un adressage postindexé (où 
le processeur ajoute la valeur du registre Ÿ à 
l’adresse trouvée dans un vecteur de page zéro). 
Les configurations de bits (exceptions) qui doi- 
vent être envoyées au port utilisateur pour com- 
mander les moteurs sont produites de la façon 
suivante. La valeur binaire 01111111 est néces- 
saire pour mettre le moteur 7 hors tension; 
10111111 pour le moteur 6, etc. Ces valeurs sont 
générées en chargeant $FF dans le registre À et en 
mettant à zéro le drapeau de report. Puis, tandis 
que la routine gère chaque exception à tour de 
rôle, ces bits sont décalés d’une position vers la 
droite. Lors de la première rotation, le bit de 
report passe au bit 7, le bit 7 passe au bit 6, et 
ainsi de suite, jusqu’à ce que le bit 0 remplace 
le bit de report. La configuration de bits requise 
pour mettre chaque moteur hors tension est sau- 
vegardée temporairement sur la pile. 

Après la création du code machine, l’événe- 
ment 5 est remis à zéro. Appuyer sur la touche 
Shift avec une touche numérique de 1 à 8 solli- 
cite l’un des moteurs, tandis que presser les 
touches 1 à 9 place les moteurs en position. 


Utilisation des listages 


Pour utiliser les listages du BBC, tapez-les tels 
quels, sauvegardez-les, puis exécutez-les. Les lis- 
tages monomoteur et multimoteur sont tous deux 
exécutés avec la routine initiale commune. 

Pour le Commodore 64, le second algorithme 
utilise les mêmes touches de commande que le lis- 
tage du BBC. Le programme d’appel BASIC per- 
met de régler la position de chaque moteur de 
façon indépendante : la touche Shift et une tou- 
che numérique sollicitent le moteur désiré, et une 
touche de 1 à 9 définit la position requise. 

Si vous avez un assembleur, tapez le listage 
source et assemblez-le dans un fichier objet qui 
pourra être chargé par le programme d’appel 
BASIC. Vous pouvez également taper le chargeur 
du code machine BASIC et l’exécuter. Tapez NEW 
avant de charger et d’exécuter le programme 
d’appel BASIC. Si vous utilisez le chargeur BASIC, 
les lignes 30 et 40 peuvent être supprimées. 


Commodore 64 


Commande servos multiple 


Code source 


AOBO 1444444 

1DID téreseresteseseetesetetee 

1020 1++ ++ 

1838 1++ COMMANDE CBM + 

184@ ++ SERVOS MULTIPLES ++ 

1058 1++ ++ 

1QBS rerressreseresethere tete 
Détéstéeserseresees etes 

1288 : 

1090 PORT = 56577 :USER PORT DATA REGISTER 
ANGLE=12288 ANGLE VALUE LOCATION 
IPAGE=6FB 18 PAGE POINTER TO TABLE 


tINTERRUPTS OFF 
s0314 1EXISTING IRQ VECTOR 
sasca 
#e3ca 
*esié 
*0315 
sacs 
#o3cs 
LME 


INITIALISER TABLE ++++ 


LDA #4FF 


FINTERRUPTS ON 


GESTION EVENEMENT ++++ 
PHP 


SAUVE REGISTRES 
ON STACK 


t++ DEMARRER IMPULSION, POUR CERTAINS MOTEURS IL EST 
1POSSIBLE DE DEMARRER AVANT DE REMPLIR LA TABLE ET DE 


FREDUIRE LA BOUCLE D'ATTENTE QUI SUIT ++ 
3 

LDA 68FF 

STA PORT 
1++ REMPLIR TABLE D'EXCEPTIONS ++ 

LDX #07 

LDR #8FF 


*BIT PATTERN 
ANGLE, X 1GET MOTOR X OFFSET 
(IPAGE), Y 1KEEP EXISTING PATTERN 
(ZPAGE), Y BUT MODIFIED FOR MOTOR X 


DEX 
BPL 
++ TABLE 
LDY 
WAIT 
1FILL IN SOME 
TIME 


FALL PULSES ON 


Y 3:BUT MASK OFF WITH EACH 
STABLE ELEMENT IN TURN 


ANGLE, x FCLEAR ALL EXCEPTIONS 
(ZPAGE) , Y 


CLEAR 


1++ TOUTES LES IMPULSIONS DOIVENT ETRE TERMINEES ++ 


FRESTORE REGISTERS 


Programme chargeur basic 


19 REM +ves CHARGEUR BASIC POUR ss 
« 

20 REM ses SERVOS MULTIPLES 4e 
+ 

3e : 

40 FOR 1=828 TO 922 

Se READ AIPOKE !,A 

6e CC=CC+A 

7@ NEXT ! 

6e READ CS:1F CS<>CC THEN PRINT" 
CHECKSUM ERROR* 1STOP 

188 DATA120. 173, 28. 3, 174, 196, 3, 1 
41,196 

118 DATAS, 142, 28, 3, 173 21: 3, 174, 
197,3 

120 DATAIA1, 197,3, 142, 21, 3, 168,2, 
s3.160 

138 DATA. 145, 251, 135, 208, 251,88 
..8 

148 DATA72, 152, 72, 138, 72: 169, 255 
"ia 

158 DATA221, 162, 7; 163, 295, 24, 186, 
72 

168 DATA1BB, ©. 48, 48, 251,145, 251, 
184 

178 DATAZ82, 16, 243, 160, 48, 136, 20 
8.253 

188 DATA1S9, 255, 160. @, 49, 251, 141 
*1,221 

198 DATA288, 288, 248, 162, 7, 169, 2 
188 

200 DATAO, 48, 145, 251, 202, 16, 268 
184 

218 DATA178, 184, 168, 184, 48, 76, 45 
23% 

228 DATA1SO72:REMTOTAL DE CONTROLE* 


Programme d'appel basic 


18 REM es SERVOS MULTIPLES sus 
2e : 

30 ON=B:REM SI CASSETTE ALORS ONe 
1 

4 1F Ang THEN A=1:LOAD'MULTISER 
Va HEX*, DNs 1 

5e POKE 778,88: POKE 779, J1REM P 
DINTER TO EVENT HANDLER 

60 POKE 251.0: POKE 292, 491REM $ 
ET UP ZERO PAGE PTR 

7 DDR= S65791:POKE DDR, 2SS1REM À 
LL OUTPUT 

20 MC=B20: SYS MC 

se : 

108 GET KS:1F Ke="" THEN 180:REM 
AWAIT KEY 

118 REM «+ MODIFIER POSITION MOTEUR 
. 

115 AKMASC (KE) 

120 1F AK 48 AND AK<SB THEN POKE 
12288+SERV0, VAL (KS)#20 

138 IF AK>32 AND AK<AB THEN SERV 
O=ASC KS -35 

148 IF K8CD"E" THEN 1881REM ‘E" 
TO ExIT 


Commande d'un seul servomoteur 


735 REM seroeseenee sers se 
756 REM ASSEMBLER LE CODE MACHINE 
TS7 REM émettent 
10000 DEF PROCinitiai 
10010 DIM spacex 208 
10020 FOR C=@ TO 2 STEP 2 
10058 Portb=8FE68 
18049 PA=spacex 
12050  ansie=Px 
10060 PA=PA+i 
10078  COPT C 
10088  .eventhandier 
12030 \save resisters first 
PHP 2 PHARE TYAE PHALTXAI PHA 
LDA 4484 
LDX £ntimer 
LOY £rtimer 
JSR aFFF1 \reset timer 
LDA £8FF 
STA sort 
\nait approx.  msec 
LDY £8FF 
«LOOP DEY 
BME LOOP 
\and countout puise 
LDY ansie 
+LOOP1 DEY 
BNE LOOP1 
10250 \stos ail outeut puisses 
18260 LDA 440 
10270 STA portb 
10280 PLA: TAX PLAE TRY: PLAIPLP 
10290 RATS 
18:08 2 
18319  NEXT C 
18320 REM Pointer sestion d'événements 


18338 '4220=eventhandier OR (4229 AND 4FFFD2B0) 


18348 ENDPROC 


Li 


BEBSSSESSS 


stages BBC Micro 


RE“ mens 

REM SOLLICITER CE CHRONOMETRE ETC. 

REM 

osbrtensFFFa 

RXMES7 1XXMREZ IVXMBFF 

CALL osbyrte:REM Mettre le sort B en sortie 

cs 

DIM »%(8) 

DIM timerx 12, RERDX 12 

timeretinerx MOD 256 

Ytimeretimerx DIV 256 

nrend=readx MOD 256 

rread=reaux DIV 256 

PROCinitiai 

FOR Ixmansie TO ansie+Bransie?1X=128INEXT 

1.02 1REM sec entre imouisions 

timeXeBFFFFFFFE —C#180) +1 

timer XPamaFF 1REM charger octet aupérieur 

ltimertmtimex  2REM solliciter le Chrono, autoriser 
les événements 

#FXL4,5 

Aém IXXextimer 1YXmytimer 1CALL SFFFI 


PRINT"Abpurez sur SHIFT + nombre Pour 
sélectionner un moteur" 
PRINT"Aepurez sur nombre Pour Choisir l'ansie" 
motor=i 
REPERT 
A=GET 
IF>A 82F AND AÇASA THEN a=(R-838)+18e(255/ 90) : a 
(motor-1)=a1PRINTTAB(18, motor)1"motor “motor * 
ansie “ae(90/255) 
IF A>820 AND À 82A THEN motor=ñ-428 
UNTIL @ 
END 


Commande servos multiples 


SES 262Hdsiaddi 


REM sens De 
REM ASSEMBLE CODE MACHINE 
BEM snssmeneseneentesmennne 
DEF PROCinitiai 
DIM seacex 508 
FOR C=8 TO 3 STEP 3 
zeropase=478  :REM libre pour utilisateur 
DOrtb=4FES 2osmord=&FFF1 
Prespacex 
ansie=Px :PXaPX+E 1REM © moteurs potentiels 
tabie=PX 1PX=PX+25E 1REM 256 loneueurs d' imousi ion 
possible 
FORIX=tabie TD tabie+8180: 71X=8FF 2NEXT 
lomtabietetabie MOD 255 
hishtabiekstabie DIV 256 
Tzeropaseiontabiex 126 0pa8071mhiShtaD ex 
toPr € 
-eventhandier 
PHP: PHAITYRE PHAI TXA: PHR 
LDA £8œ8 
LDX £xtimer 
LOY Evtimer 
JSR osmora 
\Démarrer l'imouision pour certains moteurs || neut 
le de démarrer avant de réduire ainsi 1e 


LDA £SFF 1STA porte 
\remsiir ia table d'excestions 
LOX £875LDA EBFF ICLC \contisuration de bits 
…exceetions 
ROR À 1PHA  lconfisuration de bits 
LDY anniesX Décaiase correspondant à l'angle 
du moteur X 
AND (zeropase).YŸ \rarder la confisuration 
STA (zeropane).Y existante mais modifier Pour le 
moteur X 
PLA 1DEX 
BPL excentions 
Wtatie charmée, remplir 
LOY LsEe 
wait DEY 
ONE mait 
LDA £&FF toutes imeuisions ON 
LDY £88 
"loop AND (zeropase),Ÿ \mais masauer chaque élément 
STA porte de la tabie un élément à la fois 
LS 
BNE 100 
LOX 487 #LDA EBFF 


"X \mettre à zéro toutes les excestions 
STA (zeropase), Y 

DEx 

BPL clear 

\toutes les imeuisions doivent être 

PLAI TAKE PLAI TAYEPLAI PLP 

RTS 

1 

NEXT © 
l822%eeventrandier OR (!4220 AND &FFFFRDOD) 
ENDPROC 


Un écran avenant 
Bienvenue! c'est le premier 
mot que l’on peut lire sur 
cet écran du Goupil-LOGO. 
Une marque de civisme à 
laquelle les enfants ne 
sont pas insensibles. 

(CI. Goupil.) 
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Du Lego au logo 


Quand l’ordinateur se fait précieux auxiliaire dans l’éducation des 
enfants, LOGO est un des langages privilégiés. Cherchons à savoir 


le pourquoi et le comment. 


L'âge de trois, quatre ou cinq ans est celui de la 
création et de la construction. Entre les blocs à 
empiler, les Lego à assembler et d’autres cubes 
à emboîter, les petits doigts acquièrent de l’habi- 
leté, tandis que l’esprit se structure. Pour l’aider 
dans cette tâche qui se poursuivra encore durant 
des années, l’ordinateur est un instrument mer- 
veilleux, à condition de s’en servir correctement. 
C’est lui qui fournit des « matériaux » à 
l’« enfant constructeur ». 

Si le BASIC est un langage simple pour ceux qui 
le maîtrisent (et sont en outre un peu familiari- 
sés avec l’anglais), il peut être indiqué pour les 
adultes qui veulent s’initier à l’informatique (car 
il s’apprend facilement et permet d’écrire des pro- 
grammes en peu de temps), il est cependant trop 
rigide et peu structuré, et ne convient guère aux 
jeunes enfants. À ceux-ci, il importe de fournir 
un langage qu’ils puissent apprendre comme leur 
langue maternelle. L’idée de s’inspirer de la 
manière naturelle dont un enfant apprend à par- 
ler est à la base du LOGO (voir encadré). 

LOGO, c’est à la fois une conception de la 
pédagogie et la famille de langages de program- 
mation allant de pair avec elle. Toutes deux ont 
été conçues par un groupe de recherche, dirigé 
par Seymour Papert, au laboratoire d’intelligence 
artificielle du Massachusetts Institute of Techno- 
logy (MIT). De même que le nourrisson apprend 
à parler en progressant dans la compréhension 
à partir de rien, de même l’enfant peut travailler 
ou jouer avec l’ordinateur, sans présupposer la 
connaissance de la lecture ni de l’écriture au 
départ : en retrouvant des mots dans un certain 
contexte, il parvient à leur donner un sens, et ces 
mots lui servent à leur tour pour en comprendre 
d’autres. Si un langage informatique est appris 
et couramment parlé dans les premières années 
de la vie, il sera pratiquement assimilé par 


l’enfant comme sa langue maternelle, sans réel 
effort et sans qu'aucun enseignement lui soit 
imposé délibérément. Cet apprentissage peut 
alors modifier la façon dont l’enfant abordera 
le reste des connaissances, en particulier les 
mathématiques et la logique. 

Selon Seymour Papert, le rôle de l’ordinateur 
est celui de porteur de « germes » culturels qui 
s’enracineront dans un esprit en croissance active. 
L'important est d'acquérir ces germes assez tôt. 
C’est là ce qui distinguera ultérieurement les 
« matheux » des « nuls en maths ». Mais la 
question n’est pas de produire uniquement des 
mathématiciens. Le rôle de l’informatique, et 
notamment des langages de type LOGO, est 
d’aider à comprendre comment nous pensons et 
comment nous apprenons à penser. L'ordinateur 
fournit des « objets avec lesquels penser », selon 
S. Papert. La « tortue » LOGO est un tel objet. 
Le rôle de l’enfant consiste alors à dire à la tor- 
tue ce qu’elle doit faire et, dans un second temps, 
à lui apprendre des choses, par exemple des mots 
nouveaux, des procédures. Ainsi est introduite 
l’idée de programmation. 

Alors qu’en E.A.O (enseignement assisté par 
ordinateur) c’est généralement l’ordinateur qui 
« programme » l’enfant en lui faisant faire des 
exercices dont les réponses sont prédéterminées, 
en environnement LOGO, la situation est renver- 
sée : l’enfant, dès le début, maîtrise la machine. 
C’est lui qui apprend à l’ordinateur à « pen- 
ser » et, par là, il parvient à retrouver comment 
il pense lui-même. En retraçant ainsi la genèse 
de l’acquisition du savoir (les principes déductifs 
comme la transitivité, les divers principes de 
conservation, la logique intuitive, les classifica- 
tions, etc.), l’enfant se fait épistémologue avant 
la lettre. Peu à peu, il apprend à exercer un 
contrôle sur un microcosme riche et complexe. 

Programmer en LOGO devient un jeu pour 
l’enfant. Une séance devant l’ordinateur suffit à 
l’imprégner de l’« univers-tortue », si bien qu’il 
n’est pas rare qu'après avoir éteint la machine 
l’enfant prolonge l’exercice en jouant à être la 
tortue, et demande à l’adulte qui le guide de lui 
donner des instructions : « Avance 10 » (l’enfant 
avance de dix pas), « droite 90 » (il tourne à 
droite d’un angle droit), « recule 4 » (il recule 
de quatre pas), et ainsi de suite. 

Par la suite, les enfants apprendront que l’ordi- 
nateur peut aussi manipuler, outre la tortue, des 
sons pour faire de la musique, et des mots qui 
les mèneront progressivement à toutes les subti- 
lités de la programmation. 


L'ordinateur sans peur 
et sans reproches 


Si l’enfant n’est pas l’esclave passif de l’ordina- 
teur comme il le serait d’un téléviseur, à l’opposé 
il n’en est pas non plus le maître tout-puissant. 
La machine ne fera pas tout ce qui lui est 
ordonné; il faut toujours respecter certaines 
règles de langage et de structure; il faut appren- 
dre à lui parler, l’« apprivoiser ». 

Très vite, l’enfant se rendra compte que l’ordi- 
nateur est un objet qui doit être utilisé d’une 
façon bien particulière pour donner les résultats 
qu’on en attend. 

Au cours de cette période d’apprentissage 
— qui d’ailleurs durera aussi longtemps qu’il se 
servira d’un ordinateur — l’enfant ne connaîtra 
jamais d’échec. Si en BASIC il y a encore des 
« erreurs » (syntax error ou autres) à corriger, en 
LOGO il n’y en a même plus. 

Tout au plus l’ordinateur demande-t-il aima- 
blement de préciser un terme, de compléter une 
instruction. Les messages apparaissant à l’écran 
seront par exemple : || manque quelque chose après DROITE 
ou Que dois-je faire avec 36? ou encore XXX n'aime pas recevoir 
Ye 

De monstre effrayant qu’il était à ses débuts, 
l’ordinateur, en devenant « micro », s’est fait 
compagnon domestique, à la mesure de ses utili- 
sateurs, même et surtout des plus jeunes. 

Aujourd’hui, grâce à cet outil fantastique, le 
pouvoir de choisir des méthodes d’enseignement 
devrait revenir petit à petit aux particuliers. 
L'éducation deviendra davantage une affaire pri- 
vée : les bonnes idées en la matière pourront 


d’emblée être mises en œuvre sans avoir à pas- 
ser le barrage rigide du système scolaire natio- 
nal. Nous devrions dès lors assister peu à peu à 
une renaissance de la pensée pédagogique qui est 
restée trop longtemps l’apanage d’administra- 
tions sclérosées. 

Donc, parents et éducateurs, tous à vos 
ordinateurs ! 


Patience et informatique 
La patience est aussi une 
qualité dont savent faire 
preuve les enfants. Il en 
faut pour assembler des 
Lego, il en faut aussi pour 
faire ses premiers pas au 
« pays informatique ». 


Logo, un nouvel univers 
pour l'enfant 


Le langage informatique LOGo a été créé 
par Seymour Papert (laboratoire d’intel- 
ligence artificielle du MIT), en application 
des idées du psychologue Jean Piaget 
sur le développement intellectuel de 
l'enfant. Selon Piaget, les enfants sont 
eux-mêmes les bâtisseurs de leurs pro- 
pres structures intellectuelles : « Com- 
prendre, c'est inventer ou recréer par 
l'invention ». 

L'environnement LoGo fournit, par 
l'intermédiaire de l'informatique, un 
« micro-monde » sur lequel l'enfant va 
pouvoir intervenir en développant des 
stratégies de pensée pour résoudre les 
problèmes rencontrés et en découvrant, 
par ce biais, les lois qui régissent ce 
« micro-monde ». 

Pour le plus jeune enfant, il s’agit 
d’abord de l’« univers-tortue ». Au moyen 
de commandes simples — AVANCE, RECULE, 
DROITE, GAUCHE, suivies de valeurs numéri- 
ques, et RÉPÈTE, POUR, VIDE-ÉCRAN, etc. —, 
l'enfant crée des formes à l'écran à l’aide 
de la « tortue » qui est, en fait, un petit 
curseur triangulaire se déplaçant dans la 
direction de son sommet, sur l’écran, sui- 
vant les instructions qui lui sont données 
par l'intermédiaire du clavier. 


Les programmes suivants pour tracer 
un carré, écrits respectivement en BASIC 
et en LoGo, montrent la puissance, la 
concision et surtout la « convivialité » de 
ce dernier langage par rapport au 
premier. 


BASIC 


10 FOR À = 0 TO 10: SET (0,A) : NEXT À 
20 FOR B = 0 TO 10: SET (BA) : NEXT B 
30 FOR À = 0 TO 10 : SET (B,10 - A) : NEXT À 
40 FOR B = 0 TO 10: SET (10 - B,A) : NEXT B 


LOGO 
RÉPÈTE 4 [DROITE 90 AVANCE 10 


Cet « univers-tortue » met l'enfant en 
présence de toute une série de notions 
formant le cœur même du calcul différen- 
tiel : dans le tracé d'un cercle, par exem- 
ple, c'est le « changement d'état » (posi- 
tion et direction) qui importe, et non l’état 
dans l'absolu, comme c'est le cas pour 
un repère cartésien; c'est en cela que le 
LOGO favorise tout à la fois la concrétisa- 
tion des lois abstraites et une familiari- 
sation précoce et active avec des notions 
mathématiques ou physiques. Par là 
même se trouvera encouragée l’acquisi- 
tion de connaissances scientifiques qui 
s'enracineront dans l’activité intuitive et 
personnelle du futur étudiant. 

La richesse et la puissance de la pro- 
grammation en LoGo sont liées à la pos- 
sibilité de définir un mot à partir d’instruc- 
tions de base, ou « primitives ». Une telle 


« procédure » équivaut pour l'enfant à 
«enseigner » un nouveau mot à l’ordina- 
teur. Voici un exemple de procédure : 


POUR CARRÉ 
RÉPÊTE 4 DROITE 90 AVANCE 10] 
FIN 


Dès lors, l'ordinateur « sait » ce que 
signifie « carré ». Les mots ainsi définis 
peuvent à leur tour être utilisés dans 
d’autres procédures. Cette particularité 
débouche notamment sur la récursivité, 
dont voici un exemple simple : 


POUR CERCLE 
AVANCE 1 
DROITE 2 
CERCLE 

FIN 


De toutes les notions enseignées aux 
enfants, la récursivité est bien la plus 
marquante et la plus enthousiasmante. 
C'est un processus qui peut se pour- 
suivre indéfiniment — un peu comme le 
couvercle de ces boîtes de fromage sur 
lequel est dessinée une boîte plus petite, 
sur laquelle est dessinée encore une 
boîte, et ainsi de suite. L'image devenant 
de plus en plus minuscule à chaque 
étape. En LOGo, au contraire, les graphi- 
ques deviennent de plus en plus com- 
plexes à chaque étape, et le processus 
peut continuer jusqu’à ce que l'écran soit 
entièrement couvert. De quoi faire rêver 
les enfants! 
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Jean Raby, éd. ATLAS 


S'il fallait trouver un équivalent concret d’une boucle en informatique, 
on pourrait songer à une noria. Mais dans l’un et l’autre cas, il faut 
savoir arrêter le mouvement. 


nt mat inlicati La boucle inconditionnelle — que nous avons 
Table de multiplication Table de multiplication déjà vue — a des applications limitées. Suppo- 
|usqu a l'infini jusqu a 10 sons que l’on souhaite montrer sur l’écran la table 


de multiplication d’un nombre quelconque, sans 
qu’il y ait de limite. L’organigramme prend une 


forme équivalente à celle apparaissant dans la 
DÉBUT figure 1. On part, comme base, du nombre de 
la table de multiplication que l’on souhaite visua- 


liser. La zone NOMBRE correspond alors aux 
différentes valeurs qui, après une augmentation 


systématique d’une unité, vont multiplier la 
ENTRER BASE. Une suite de résultats apparaît donc 

ENTRER BASE : ; ; : : 
BASE visuellement sur l’écran. Il n’y a pas de fin, si ce 
ne sont les capacités de calcul de l’ordinateur ou 
encore l’intervention humaine. La personne qui 


observe le déroulement du programme peut pren- 

dre la décision de le stopper. 
NOMBRE Les boucles conditionnelles se caractérisent 
Ÿ donc de la manière suivante : leurs fins dépen- 
NOMBRE dent toujours d’une décision : soit envoyer la 
À séquence de multiplications qui se répètent, soit 
sortir du cycle. Reprenant l’exemple de la table 
de multiplication, supposons que l’on veuille 
visualiser les dix premiers éléments de la table. 
RÉSULTAT = Le programme correspond à celui indiqué par la 

BASE x figure 2. La nouveauté apparaît dans la présence, 

NOMBRE pour la première fois, du losange qui est la mar- 
que d’une décision. Pour savoir si le nombre, 
convenablement augmenté après le calcul, puis 
affiché, a dépassé la valeur 10, nous sommes en 
présence de deux issues possibles. Si la condition 
n’est pas remplie, c’est-à-dire si le nombre est 
encore parmi les dix premiers, le flux retourne 
au début du cycle; dans le cas contraire, la 
séquence sera dérivée vers la fin de l’organi- 
gramme. 

Il est possible, à n’importe quel moment, 
d’augmenter ou de diminuer l’intervalle, c’est-à- 
NOMBRE = dire le nombre de fois que le cycle va être répété; 
pp + il suffit simplement de changer la valeur inscrite 
dans le symbole de décision. 

Un même programme peut contenir un nom- 
bre indéterminé de boucles, interdépendantes ou 


non. 
NOMBRE 
La répétition se 
produira 5 fois 
SI 


RÉSULTAT = 
BASE x 
NOMBRE 


NUMÉRO = 
NOMBRE + 
1 


Le processus se répétera 
25 fois 


Figure 1 Figure 2 
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Les petits Sharp 


ru 


Nous avons déjà examiné de près la gamme d’ordinateurs de poche 
Casio. Jetons maintenant un coup d’œil sur les deux machines 
Sharp, assez différentes l’une de l’autre. 


Sharp produit deux ordinateurs de poche assez 
différents alors que Casio propose trois machi- 
nes relativement similaires. Les deux machines 
Sharp n’ont pas été conçues de façon à créer une 
concurrence interne : le PC-1251 est le plus petit 
ordinateur de poche offert sur le marché; le 
PC-1500A est beaucoup plus gros, plus puissant. 
Il est l’ordinateur le plus cher offert par ces deux 
sociétés. 

Le Sharp PC-1251 pèse à peine 115 g et mesure 
135 X 70 X 10 mm. La taille du clavier n’est que 
la moitié de celle d’un clavier standard et les tou- 
ches n’ont que 4 mm de largeur. En plus du cla- 
vier alphabétique, on retrouve un clavier numé- 
rique qui permet d’utiliser l’ordinateur comme 
une simple calculatrice. 

Le PC-1251 est doté d’un affichage à cristaux 
liquides de 24 caractères. Celui-ci peut être ajusté 
en fonction de différentes conditions d’éclairage 
au moyen d’une petite roue située sur le côté de 
l’ordinateur. Le commutateur Mode Selector est 
situé à la droite de l’affichage. Il existe trois 
modes de fonctionnement : l’un d’eux permet de 
définir les fonctions de certaines touches (RSV); 
un second facilite la programmation (PRO); et le 
dernier permet d’exécuter un programme BASIC 
ou d’utiliser la machine comme une calculatrice 
(RUN). Ce commutateur sert également à mettre 
l’ordinateur hors tension. 

La version de BASIC utilisée est excellente pour 
une machine de cette dimension. Elle offre des 
commandes absentes sur certains ordinateurs de 
poche Casio, comme ASC et CHR$, mais comme le 
BASIC de Casio elle ne comporte pas l’option 
ELSE pour l'instruction |F...THEN. Comme les petits 
ordinateurs Casio, le BASIC du PC-1251 utilise 
les mêmes noms à une lettre pour les chaînes et 
pour les variables. Cela signifie que si la varia- 
ble À a été utilisée pour contenir un nombre, la 
chaîne A$ ne peut être utilisée. De plus, certains 
tableaux occupent les mêmes zones de mémoire. 

Uniquement neuf messages d’erreur sont pro- 
duits par cette version de BASIC, et il ne s’agit que 
de simples lettres qui sont d’une piètre assistance 
lors de la mise au point des programmes. Comme 
option supplémentaire, la commande PASS per- 
met de protéger des programmes à l’aide d’un 
mot de passe. Les numéros de lignes du BASIC 
sont limités de 1 à 999. En mode d’entrée de pro- 
gramme, deux touches de commande de curseur 
permettent au programmeur de faire défiler les 
lignes de programme vers le haut ou vers le bas. 
Deux autres touches de curseur permettent aussi 
le défilement latéral dans tous les modes. 


Comme il y a très peu de logiciels offerts pour 
la machine, la plupart des utilisateurs doivent 
écrire leurs propres programmes. Le manuel 
d’utilisation offre deux types d’aide. Il constitue 
d’abord un bon guide pour le BASIC, facile à 
comprendre. Deuxièmement, il renferme les lis- 
tages de neuf courts programmes, qui n’ont pas 
tous nécessairement des applications mathéma- 
tiques (trouver des racines carrées, des écarts- 
types, etc.); un programme d’exercice de dacty- 
lographie et un programme de jeu sont également 
offerts parmi d’autres. De plus, Sharp offre à un 
prix relativement modeste trois bandes contenant 
une sélection de programmes. 

Alors que les ordinateurs Casio peuvent loger 
jusqu’à dix programmes en mémoire simultané- 
ment, le PC-1251 est limité à un à la fois. Il est 
toutefois possible d’utiliser un programme com- 
posé de plusieurs sous-programmes, séparés par 
des instructions END. Il est possible d’exécuter un 
sous-programme en utilisant une instruction 
GOTO avec le numéro de ligne approprié. Il est 
souvent utile d’avoir plusieurs programmes en 
mémoire simultanément, puisque la seule façon 
de charger des programmes consiste à taper leurs 
noms lorsqu'ils sont nécessaires. De plus, l’ordi- 


Puissance miniature 
Avec une RAM CMOS et 
une unité centrale à 8 bits, 
un clavier QWERTY, 

le langage sasic et une 
gamme de périphériques 
optionnels, ces 

« calculatrices » Sharp 
peuvent revendiquer 
l'appellation de 
micro-ordinateurs 
véritablement portables. 
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nateur n’a que 4 K de mémoire, ce qui représente 
un espace tout juste suffisant pour loger quelques 
programmes BASIC modestes. Ce qui signifie que 
la présence optionnelle de l’imprimante et de 
l’unité à cassette est presque essentielle si l’on pré- 
voit une utilisation sérieuse. 


Le Sharp PC-1500A 


L’autre ordinateur portable Sharp, le PC-1500A, 
est une version améliorée du modèle précédent 
(le PC-1500) et est destiné à des utilisateurs plus 
sérieux. Le PC-1500A mesure 195 X 85 X 
25 mm et pèse 375 g, ce qui est trois fois plus 
lourd que le PC-1251. 

Le PC-1500A est muni d’un meilleur clavier 
et d’un écran légèrement plus grand que son 
petit frère. L'affichage à cristaux liquides est 
légèrement élargi (26 caractères au lieu de 24) 
et la fonction pratique d’ajustement d’écran 
du PC-1251 n’apparaît pas sur la plus grosse 
machine. 

La version de BASIC est toutefois considérable- 
ment améliorée. Les variables peuvent avoir des 
noms à deux lettres, et les mêmes noms peuvent 
être utilisés pour désignér les variables numéri- 
ques et de chaînes sans causer de confusion. Le 
BASIC comporte aussi certaines fonctions sono- 
res et graphiques. Il est possible de concevoir des 
motifs sur l’écran à cristaux liquides avec une 
résolution de 7 lignes par 156 colonnes. La com- 
mande BEFP de l’ordinateur permet de moduler la 
hauteur et la durée des notes, qui sont raisonna- 
blement fortes. 

L'ordinateur possède un calendrier et une hor- 
loge intégrés qui peuvent être adressés à l’aide de 
la variable TIME. Ceux-ci continuent à fonction- 
ner même lorsque l’ordinateur est mis hors ten- 
sion; il n’est donc pas nécessaire de les régler lors 
de chaque mise sous tension. Cette fonction serait 
une option pratique sur tout ordinateur dorñes- 
tique. Le BASIC du PC-1500A comporte plusieurs 
autres commandes qui rendent la machine 
plus performante que de nombreux ordinateurs 
domestiques. Parmi ces commandes, citons la 
commande ON ERROR GOTO et les fonctions de trace, 
TRON et TROFF. Il comporte une généreuse série de 
trente-neuf messages d’erreur pour l’ordinateur 
standard ; seize autres sont disponibles pour des 
commandes utilisées uniquement avec des unités 
complémentaires. Mais comme pour le PC-1251, 
ces messages d’erreur ne sont que des numéros 
et pourraient être plus utiles. 

La rangée du haut des touches alphabétiques 
inclut des mots clés BASIC, et il est possible de 
poser une étiquette au-dessus des touches pour 
identifier les dix commandes. Il est assez étrange 
que Sharp n’ait pas choisi d'imprimer ces noms 
de commande sur les touches — l’étiquette est 
facilement égarée. Il est possible de programmer 
jusqu’à dix-huit fonctions sur les six touches 
situées au-dessus du clavier principal. 

Les utilisateurs du PC-1500A devront écrire la 
plupart de leurs programmes : peu de sociétés 
produisent des programmes pour la machine 
et Sharp ne vend qu’une seule bande de pro- 
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grammes. Un livre accompagnant la machine liste 
cinquante-trois programmes, avec une variété 
d’applications dans cinq domaines principaux 
— mathématiques, statistiques, électricité, travail 
de bureau et jeux. Ces programmes furent écrits 
à l’origine pour le PC-1500, mais fonctionnent 
tous parfaitement sur le PC-1500A (la seule dif- 
férence entre les deux modèles se situe au niveau 
de la taille de la mémoire RAM). Le modèle anté- 
rieur avait 3,5 K de mémoire, tandis que le 
PC-1500A en a 8,5 K. Grâce au connecteur de 
cartouches situé sous la machine, il est possible 
d’augmenter la quantité de mémoire disponible. 
Quatre cartouches de mémoire sont offertes mais 
elles sont toutes assez chères. Les modules de 
mémoire standard de 4 et 8 K conservent leur 
contenu uniquement lorsqu'ils sont dans la 
machine. Deux autres cartouches renferment des 
piles, leur contenu peut donc être conservé même 
lorsqu’elles sont retirées de l’ordinateur. Celles- 
ci ont des capacités de 8 K et de 16 K. 

L'unité d’interface d’imprimante-traceur et de 
cassette est un achat plus judicieux. L’interface 
de cassette permet de sauvegarder et de charger 
des programmes au moyen d’une unité à cassette 
ordinaire — et Sharp offre une unité à cassette 
compatible. La partie imprimante-traceur de 
l’unité utilise quatre stylos à bille pour tracer des 
lettres et des graphiques de qualité en quatre cou- 
leurs. Elle est presque identique à de nombreu- 
ses autres imprimantes-traceurs offertes sur le 
marché de l’ordinateur domestique, mais utilise 
uniquement du papier de 57 mm de largeur, ce 
qui constitue une restriction importante. 

Le BASIC comporte une série complète de com- 
mandes permettant d’utiliser l’imprimante- 
traceur. Celles-ci sont les suivantes : CSIZE pour 
produire des lettres de diverses dimensions, 
ROTATE pour imprimer des lettres inclinées ou 
inversées, COLOR pour sélectionner la couleur du 
stylo, LF pour déplacer le papier vers le haut ou 
vers le bas, LPRINT pour imprimer un texte, LCUR- 
SOR et GLCURSOR pour déplacer le stylo dans le 
mode texte et dans le mode graphique, SORGN 
pour définir l’origine, et LINE et RLINE pour tracer 
une ligne entre deux points en utilisant respecti- 
vement des coordonnées absolues et relatives. 

Deux autres dispositifs complémentaires 
importants sont proposés pour le PC-1500A. 
L'un est une interface Centronics et RS232, qui 
permet à la machine de communiquer avec de 
véritables imprimantes et avec de gros ordina- 
teurs. L’autre périphérique se nomme une « carte 
logiciel ». Il s’agit d’un grand clavier à touches 
sensitives qui compte 140 touches qui peuvent 
être programmées pour exécuter des tâches fré- 
quentes (comme le calcul automatique de totaux 
dans des applications de tableur). 

Bien que le PC-1500A puisse être transformé 
en un système puissant aux caractéristiques 
impressionnantes, de nombreux systèmes micro- 
informatiques sont plus souples et disposent 
d’une plus large gamme de logiciels. En tentant 
de se démarquer dans sa catégorie, le PC-1500A 
risque de ne pas pouvoir concurrencer de nom- 
breuses machines de la catégorie supérieure. 


Logement des piles 

C'est ici que sont placées 

les quatre piles nécessaires au 
fonctionnement de l'ordinateur. 


uc 

Cette puce spécialement 
construite gère les 
opérations du PC-1500. 


TPS! LE 
CH es 


Port cartouche 
Cette interface permet 

d'installer sur le PC-1500 

des modules RAM 
complémentaires. Elle peut 

aussi être connectée à 

l'interface imprimante- 

traceur ou à une interface RS232C. 


ROM basic 
Cette puce renferme le Toute une famille de périphériques 
8asic Microsoft utilisé dans | Le Sharp PC-1251 s'emboîte dans l'unité imprimante- 


Prise d'alimentation 
Au lieu d'utiliser des piles, 


l'ordinateur peut être 
branché au secteur en 


utilisant un transformateur 


adéquat. 


Puce d’E/S 
Gère les périphériques 
externes, comme l'unité 
imprimante-cassette. 


l'ordinateur. 


Ne777 


Sharp 
PC-1251 


Sharp présente cette 
calculatrice comme un 
système de gestion 
élémentaire, 
probablement plus 
destiné à l'ingénieur 

et au scientifique qu'au 
gestionnaire. Les 
touches minuscules 


du clavier QWERTY 
rendent l'entrée 

de texte difficile 

et fatigante. 


microcassette CE-125. Celle-ci est composée d’une 
imprimante thermique (24 caractères par ligne) 

et d’une unité à microcassette. Les dimensions 

de l'unité sont 205 x 149 x 23 mm. 

Le Sharp PC-1500 est au centre d’une vaste famille 
d'équipements Sharp, et grâce à l'interface CE-158 
RS232C/parallèle, il est possible de le brancher à 
presque n'importe quel micro ou gros ordinateur. 
L'interface imprimante couleur-cassetté CE-150 est 
un traceur à quatre couleurs produisant neuf 375 g. 
dimensions de caractères et doté d’une option 
graphique. Les modules de mémoire CE-151, CE-155, 
CE-159 et CE-161 constituent une gamme de modules 
RAM CMOS allant de 2 à 16 K, dont certains 
renferment une ROM programmable. La carte logiciel 
CE-153 est un clavier à touches sensitives destiné à 
une entrée formatée. 


195 x 85 x 25 mm. 


RAM 8,5 K. 


Affichage à cristaux liquides 
1 x 26 caractères. 


Calendrier et horloge intégrés; 
bon sasic; extension de 
mémoire possible; large gamme 
de périphériques. 


Sharp PC-1251 


Puces RAM 

Ces puces fournissent les 
8,5 K de mémoire, dont 6,6 K 
sont à la disposition de 
l'utilisateur. 


k x 


Puces d’affichage 135 x 70 x 10 mm. 
Ces quatre puces gèrent 
l'affichage de l'écran à 


cristaux liquides. 115 g. 


RAM de 4 K. 


Affichage à cristaux liquides 


Carte de circuits imprimés 
1 x 24 caractères. 


Pour rendre l'unité plus 
compacte, la carte a été 
divisée en deux parties qui 
sont connectées au moyen 
d'une paire de câbles- 
rubans. Notez le faible 
nombre de composants, 
plusieurs ont été intégrés 
sur les puces CMOS. 


Trois modes de 
fonctionnement; 18 touches 
pouvant être définies par 
l'utilisateur; une unité à 
cassette-imprimante disponible. 


Le Sharp 
PC-1500A 


Voici un ordinateur de 
poche extrêmement 
souple de la taille d’une 
calculatrice de poche; 
sa puissance et son 
équipement optionnel 
sont ses meilleurs 
arguments de vente 

et il peut réellement 
remplir un rôle 
important dans le 
travail de bureau. Il est 
cependant probable 
qu'il ne soit perçu que 
comme un jouet pour 
cadre ou comme 

une calculatrice 
impressionnante. 


Chris Stevens 
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Nous allons voir comment créer des écrans graphiques représentant 
l’unité arithmétique et logique (ALU) et le port manche à balai 


du micro-ordinateur ZX Spectrum. 


Il nous faut d’abord faire défiler les lettres A, L 
et U jusqu’au centre de l’écran, à l’aide de gra- 
phismes haute résolution. Sur le BBC Micro, on 
y parvient en dessinant la lettre en un point de 
départ donné, puis en l’effaçant ; on la redessine 
un peu plus loin et on recommence l’opération. 
La même méthode peut être mise en œuvre pour 
le Spectrum. 

Ce dernier est doté d’une commande DRAW 
qui n’accepte que des coordonnées relatives 
— c’est-à-dire définies par rapport au dernier 
point tracé. Mais c’est précisément ce qu’il nous 
faut ici. 

PLOT nous permettra de dessiner un point de 
départ, puis nous créerons la lettre entière par une 
série de DRAW, en changeant simplement les coor- 
données du point d’origine. Pour effacer, on 
redessine la lettre telle qu’elle est, mais en inver- 
sant les couleurs, grâce à INVERSE 1 (effet activé), 
puis INVERSEO. Pour chaque position occupée par 
la lettre considérée, celle-ci sera donc tracée deux 
fois : l’une avec INVERSE 0, pour faire apparaître 
la forme de la lettre, et l’autre avec INVERSE 1, 
pour qu’elle disparaisse. 

La lettre A vient de la gauche de l’écran. 
Toutes nos instructions seront placées au sein 
d’une boucle FOR...NEXT, dont la fonction est 
d’accroître la valeur de la coordonnée x du point 
d’origine. 


Un premier croquis 


A l’intérieur de cette première boucle, nous en 
imbriquerons une deuxième, dont la tâche 
consistera à exécuter deux fois les opérations de 
tracé. X a pour valeur finale 55 : cela correspond 
à la position finale de A sur l’écran. Cette lettre 
ne doit plus, alors, être effacée, et nous pren- 
drons soin de ne passer en INVERSE 1 que si x est 
inférieur à 55. Il va de soi que ces principes des 
bases vont nous guider également dans le dessin 
des lettres L et U. Celles-ci viendront respective- 
ment se dérouler sur l’écran, depuis le bas pour 
la première lettre et depuis la droite pour la 
seconde (en fait les deuxième et troisième des 
initiales). 

Lorsqu’on entend créer une image à l’écran, 
il est toujours utile de prendre d’abord une feuille 
de papier et de faire un premier croquis som- 
maire, un brouillon en quelque sorte, afin de voir 
quelles seront les coordonnées de chaque forme 
mise en œuvre. 

De plus, toutes les lettres affichées à l’écran 
(voir ci-contre) devront elles aussi être position- 


nées en termes de rangées et de colonnes. Notre 
illustration montre à quoi ressemble notre des- 
sin une fois achevé. 

AND, OR et NOT (que nous franciserons en ET, OU 
et NON) sont placés à l’écran grâce à la com- 


mande PRINT AT rc, dans laquelle r correspond au 
nombre de rangées (en partant du haut de l’écran) 
et c au nombre de colonnes (à partir de la gau- 
che). Les boutons sont tracés à l’aide de CIRCLE 
Xy,r : x et y sont les coordonnées du centre, et r 
le rayon. 

Une fois que les motifs graphiques ont été tra- 
cés, le programme attend que vous pressiez une 
touche avant d’effacer l’écran et de revenir aux 
valeurs originales de INK et de PAPER. Il repasse 
ensuite à la routine principale ALU. INKEY$ per- 
met de tester le clavier — le test est répété jusqu’à 
ce qu’une touche soit pressée. C’est grâce à : 

4565 GOSUB 7000 : REM S/P ILLUSTRATION ALU 
que l’insertion de ce sous-programme dans le lis- 
tage de Digitaya est assurée. 


. . 

Le port joystick 

Le port joystick crache des rayons laser. Il est 
représenté graphiquement de façon très simple : 
les prises sont des points, affichés à l’aide d’ins- 
tructions PRINT, et le rebord qui les entoure est 
tracé grâce à des graphismes haute résolution. 
Une série de lignes de fuite en bas d’écran donne 
à la scène une certaine profondeur. 

Toutes partent d’un point situé sur la ligne 
d’horizon (déterminé grâce à l’instruction PLOT), 
et vont jusqu’en bas de l’écran. L’écartement 
entre elles est d’une unité à l’horizon, et de sept 
à l’autre extrémité. 


FA] 
€ 
= 
x 
GE] 
 : 
& 


La commande DRAW du Spectrum ne prend en 
compte que les coordonnées relatives, ce qui rend 
la routine de dessin un peu plus complexe, 
puisqu’à chaque fois il faut se livrer à de nou- 
veaux calculs. La boucle FOR..NEXT des lignes 
8030-8060 s’en chargera : elle intègre les diffé- 
rences d’échelle entre le centre et le bas de l’écran. 


dure avec INVERSE 1. Le rayon n’apparaît donc 
que pour un temps très bref, ce qui donne un 
effet de clignotement. 

On rencontre toutefois un problème. Le trait 
croise les bords du port manche à balai, et, 
lorsqu’il est effacé, une partie du port l’est aussi, 
et doit donc être redessinée. 


Là encore, il est bon de dessiner à grands traits 
notre illustration, de façon à déterminer ses 
dimensions et ses coordonnées. Le résultat final 
devrait être comme ceci : 


Le contrôle de la couleur 


La ligne d’horizon est également affectée. A 
cause de la manière dont le Spectrum contrôle 
la couleur, une partie de cette ligne (celle qui est 
la plus proche du rayon laser) prendra la même 
teinte que le trait venu du port joystick : le ZX 
Spectrum ne peut en effet affecter qu’une seule 
couleur INK et une seule couleur PAPER à la fois, 
dans une case d’écran donnée. 

Nous serons donc contraints de redessiner non 
seulement le port manche à balai, mais aussi 
l’horizon, et ce à chaque effaçage du rayon laser. 
Le sous-programme employé poursuit les tirs 
jusqu’à ce que le joueur appuie sur une touche; 
le programme repasse alors à la routine princi- 
pale, après avoir redonné à l’écran les valeurs 
INK et PAPER habituelles. 

La ligne suivante doit être insérée dans notre 
logiciel pour appeler la sous-routine : 


Les rayons laser sont dessinés à partir du port 3845 GOSUB 8000 : REM IMAGE PORT MANCHE À BALAI 


manche à balai : le trait part du centre de ce port 


et va jusqu’à un point de l’horizon qui, tout 
comme la valeur de l\K, est choisi de façon aléa- 
toire. Il est ensuite effacé en répétant la procé- 


Nous verrons prochainement comment il est 
possible d’adapter les deux écrans graphiques 
précédents au micro-ordinateur Commodore 64. 


Écran ALU 


700D REM es S/R IMAGE ALU ts 

7010 INK 6: PAPER @: CLS 

7015: 

7017 REM er lettre À “tot 
FOR x=@ TO SS STEP 5 
INVERSE @ 

FOR i=1 TO 2 
PLOT x» 100 
DRAW @, 38 
DRAW 15,20 
DRAW 15, -20 
DRAW @, -30 
DRAW 9,28 
DRAW -39, @ 

7110 1F x<SS THEN INVERSE 1 

7115 NEXT i 

7120 NEXT x 

7130: 

7148 REM és lettre L #é 

7150 FOR y=100 TO 159 STEP S 

7152 INVERSE @ 

7155 FOR i=1 TO 2 

7168 PLOT 113,y 

7170 DRAW @, -50 

7180 DRAW 39,0 

7190 IF y<150 THEN INVERSE 1 

7208 NEXT ; 

7210 NEXT y 

7228: 

7230 REM wwes lettre L srtm 
FOR x=255 TO 170 STEP -S 
INVERSE @ 

FOR i=1 TO 2 
PLOT x, 158 
DRAW @, -50 
DRAW 30,0 
DRAW ©, 50 


7310 IF x>178 THEN  INVERSE 1 8085 
7328 NEXT 8090 
7330 NEXT x 8100 
7sa0: g11@: 
7350 REM wwe DOUTONS rot 8120 
7360 PRINT AT 19,7:"ET" 8138 
7370 PRINT AT 10,153:"OU" 8140 
7380 PRINT AT 1@, 22: "NON" 8150 
7390 INK 3: CIRCLE 70,80.5 

7400 INK &r CIRCLE 128, 80,5 

7418 INK 5: CIRCLE 185,80,5 

7420: 

7430 REM #*% POINT inter Mk 

7435 INK 6 

7440 PLOT 113,45 

7450 DRAW ©, 15 


7460 DRAW 30,8 


7470 DRAW @,-20 

7480 DRAW -15,0 

7490 DRAW @,-7 

7500 FOR r=6 TO @ STEP -2 

7510 CIRCLE 128,23, r 

7520 NEXT r 

7530: 

7540 IF INKEY$="" THEN GO TO 7549 
7550 INK @: PAPER 7: CLS 

7560 RETURN 


Écran port manette 


8000 REM #wws S/R IMAGE PORT MANETTÉ ne 

8010 INK 6: PAPER @: CLS 

8020 REM wewr AVANT-PLAN “tk 8387 
8030 FOR n=1 TO 31 8330: 
8048 PLOT 112+n, 50 saee 
8058 DRAW 7#n-112, -50 8410 
8260 NEXT n 8415 
8070: 8420 
8080 REM kr horizon “tk 8430 


INK 6: INVERSE @ 
PLOT ©, 50 
DRAW 255, 8 


REM #oktt DOTT den 
PRINT AT 1, 185"PORT MANETTE" 
PRINT AT 3,29:" 
PRINT AT 5,213". 

158, 152 

750 

1-1 

1-1 

,-1 

td 

19, -25 

2 TR 

52,0 

-22 

18,25 

1 

ii 

o.1 

11 


REM #ti tir mot 
INK RND#7 

LET x=RND*255-194 
LET y=-86 
INVERSE @ 

FOR i=1 TO 2 
PLOT 194,135 

DRAW x» 

INVERSE 1 

NEXT i 


REM #*wkh clavier wottok 
IF INKEYS="" THEN GO TO 8088 
INVERSE © 

INK @: PAPER 7: CLS 

RETURN 
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Nous avons déjà étudié divers motifs symétriques. Aujourd’hui, nous 
abordons les figures à deux dimensions. Voyons comment définir 
avec LOGO les grilles ou treillis qui sont à la base de ces figures. 


Si, au lieu d’effectuer une translation d’une figure 
selon une ligne, nous effectuons simultanément 
deux translations non parallèles, nous obtenons 
un motif en deux dimensions. Nous prendrons 
le tiret comme unité pour ces motifs. 


POUR TIRET 
POSEPLUME AVANCE 1 RECULE 1 
LEVEPLUME 

FIN 


La procédure pour ces translations simultanées 
se définit de la manière suivante : 


POUR GRILLE :DÉBUTX :DÉBUTY :UNITÉX 
UNITÉY :ANGLE TRACE CACHETORTUE 
PLUMELEVE 
DONNEXY :DÉBUTX : DÉBUTY DONNEANGLE 0 
RÉPÈTE 3 [LIGNE :UNITÉX VERSLEBAS 
UNITÉY :ANGLE] 

FIN 


Cette procédure trace une grille de neuf points 
sur neuf. Les données en entrée indiquent les 
coordonnées du point de départ, les unités X et 
Y, et l’angle pour se positionner sur les points de 
la ligne suivante. La procédure LIGNE : 


POUR LIGNE X 
RÉPÈTE 3 [UNITÉ DONNEX COORX + :X] 
DONNEX COORX - 3° :X 

FIN 


trace une seule ligne de trois unités de long, et 
repositionne la tortue à son point de départ. Pour 
l'instant, la procédure UNITÉ est un tiret : 


POUR UNITÉ 
TIRET 
FIN 


Une autre procédure : 


POUR VERSLEBAS :Y :A 
DONNEANGLE :A 
AVANCE :Y 
DONNEANGLE 0 

FIN 


positionne la tortue sur la ligne suivante (pour 
nous, aller « vers le bas »), et redonne l’angle ini- 
tial. Les cinq types existants de grilles planes sont 
donnés dans le diagramme avec leurs procé- 
dures respectives. 

On peut obtenir un très grand nombre de 
motifs à partir de ces grilles de base, même s’il 
est probablement plus intéressant de modifier la 
procédure afin de tracer la ligne de départ selon 
différents angles plutôt qu’horizontalement. 


Un autre sujet de recherche sera de savoir dans 
quelle mesure on peut améliorer la symétrie de 
chaque grille en attribuant différents types de 
symétrie à chaque unité tracée en un point. Il 
existe dix-sept motifs de cette sorte, et tous figu- 
rent au deuxième diagramme. Une méthode évi- 
dente pour tracer la commande UNITÉ dans la 
procédure LIGNE par une procédure qui trace la 
forme géométrique en ce point. 


Formes unités 


Les formes unités sont constituées à partir d’une 
figure de base répétée selon diverses réflexions 
et rotations. Pour prendre un exemple, définis- 
sons une figure de base que nous appellerons 
BASE (comme auparavant, transparente à l’écart 
courant et n’utilisant pas de sous-procédures). 


POUR BASE 
POSEPLUME 
AVANCE 15 
DROITE 90 
AV5 
RECULE 5 
GAUCHE 90 
RECULE 15 
LÈVEPLUME 

FIN 


Nous pouvons utiliser les procédures dévelop- 
pées au dernier numéro pour créer deux nou- 
velles procédures : FIGURE, et son image en 
miroir, RÉFLECFIGURE. 


DÉFINIS «FIGURE TEXTE «BASE 
DÉFINIS «RÉFLECFIGURE RÉÉCRIS «BASE 


Nous pouvons définir maintenant les formes 
unités. Par exemple, les unités pour le motif 7 
seront : 


POUR UNITÉ 7 
GAUCHE 90 FIGURE DROITE 90 
FIN 


POUR UNITÉ 17 
DROITE 30 
RÉPÈTE 6 [FIGURE RÉFLECFIGURE DROITE 60) 
GAUCHE 30 

FIN 


Si vous vous reportez à la procédure LIGNE, 
vous constatez qu’elle exécute la procédure 
UNITÉ. Aussi, pour tracer le motif 7 par exemple, 
il faut changer UNITÉ en UNITÉ 7. Nous utilisons 
pour cela DÉFINIS.UNITÉ 7. 


POUR DÉFINIS.UNITÉ NUMÉRO 
DÉFINIS «UNITÉ TEXTE MOT «UNITÉ :NUMÉRO 
FIN 


Exécutons maintenant simultanément les pro- 
cédures de tracé de grille et de tracé de l’unité. 
Nous utilisons pour cela une procédure appelée 
MOTIF : 


POUR MOTIF :GRILLE :NUMÉRO :PROCÉDURE 
DÉFINIS «FIGURE TEXTE :PROCÉDURE 
DÉFINIS «RÉFLECFIGURE RÉÉCRIS PROCÉDURE 
DÉFINIS.UNITÉ :NUMÉRO 
L EXÉCUTE (LISTE :GRILLE) 
l EFFACE FIGURE 
EFFACE RÉFLECFIGURE 
EFFACE UNITÉ 
+ FIN 


Pour dessiner le motif 17, vous taperiez : 
MOTIF «HEX 17 «BASE 


qui tracera une grille hexagonale avec UNITÉ 17 
pour chaque point et BASE comme figure de 
base. 

Cette méthode est valable pour tous les motifs 
à l’exception des motifs 4, 6, 7 et 12. Dans ces 
derniers cas, la forme unité n’est pas la même en 
chaque point. Elle subit une transformation 
(réflexion, rotation, ou les deux à la fois). Une 
manière de traiter cette différence est d’intégrer 
ces transformations dans les procédures LIGNE et 
VERSLEBAS. Aussi nous définirons TRANSFORMATIONX 
comme la transformation à apporter à la trans- 
lation horizontale de base, et TRANSFORMATIONY 
comme celle à apporter à la transformation ver- 
ticale de base. LIGNE et VERSLEBAS deviennent 
alors : 


POUR LIGNE :X 
RÉPÈTE 3 [UNITÉ DONNEX COORX COORX + 
:X TRANSFORMATIONX] 

DONNEX COORX - 3° :X 

FIN 


POUR VERSLEBAS :Y :A 
DONNEANGLE :A 
AVANCE :Y 
DONNEANGLE 0 
TRANSFORMATIONY 


FIN 
Nous pouvons maintenant définir le motif 7 : 


POUR MOTIF7 :PROC 
DÉFINIS «TRANSFORMATIONX [ [] (RÉFLEXION DR 180]] 
DÉFINIS «TRANSFORMATIONY [ [] [1] 
MOTIF «RÉFLEXION? : PROCÉDURE 
EFFACE TRANSFORMATIONX 
EFFACE TRANSFORMATIONY 
FIN 


Pour pouvoir utiliser ce dernier, faites MOTIF/ 
«BATONNET. Après avoir exécuté la procédure ci- 
dessus, TRANSFORMATIONX aurait été définie de la 
sorte : 


POUR TRANSFORMATIONX 
RÉFLEXION 
DR 180 

FIN 
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Les dix-sept groupes plans 


P: grille à parallélogramme 
R : grille rectangulaire 
C : grille rhomboïdale 


S : grille carrée 


H : grille hexagonale 

DSR : degré de symétrie rotation 
M: rotation miroir 

D : rotation décalage 


P2 (DSR = 2) 
Rectangulaire 
(px: ren | 


gone era | 


+21 


RMM (DSR = 2) 


eg 


re 
RND (DSR = 2) 


RDD (DSR = 2) 
Rhomboïdale Treillis 
Les dix-sept motifs plans 
ci-dessus figurent selon le 
motif de base de leur grille. 
H3M1 et H3M2 par exemple 
reposent l’un et l’autre sur 
une grille hexagonale, avec 
un degré de symétrie de 
trois et réflexion en miroir. 
Leur seule différence est 
que le premier a un axe de 
réflexion horizontal et le 
second un axe de réflexion 
vertical. > 


CM (DSR = 1) 


lan McKinnell 
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Les cinq RÉFLEXION sert à effectuer une réflexion de la 
forme unité. Elle se définit en réécrivant la pro- 
types de cédure UNITÉ : 
grille POUR RÉFLEXION | 
plane DÉFINIS «UNITÉ RÉÉCRIS «UNITÉ 
FIN 


La réécriture suppose maintenant de rempla- 
cer DROITE par GAUCHE et inversement, mais aussi 
FIGURE par RÉFLECFIGURE (et réciproquement). Notre 
version précédente de la procédure de réécriture 

“ n’a fait qu’inverser DROITE et GAUCHE. Pour la 
modifier, il suffit de changer MODIFE.MOT, qui 
devient : 


POUR MODIFIER.MOT :MOT 
SILAUMOINSUN :MOT = «DR :MOT = 4 DROITE) 


ace ALORS RÉSULTAT «GAUCHE 
SI (AUMOINSUN :MOT = «GA :MOT = «GAUCHE 
nl à ALORS RÉSULTAT «DROITE 
SI :MOT = «FIGURE ALORS RÉSULTAT 
«R.FIGURE 


SI :MOT = «R.FIGURE ALORS RÉSULTAT «FIGURE 
RESULTAT :MOT 
TRANSIT FIN 


Pour la plupart des motifs, le déplacement 


ARE ‘d’un point à l’autre est simplement une transla- 
Rhomboïdale tion et il n’y a pas d’autres transformations à 
POUR RHOMBOÏDE faite. 

GRILLE (— 30) 90 80 80 225 
FIN 
Rectangulaire 
POUR RECT 


GRILLE (— 80) 90 80 50 180 
FIN 


Carrée 


POUR CARRÉ 
GRILLE (— 80) 90 80 80 180 
FIN 


Hexagonale 
POUR HEX 

GRILLE (- 30) 90 80 80 210 
FIN 
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TRANSFORMATIONX et TRANSFORMATIONY n’ont alors 
rien à faire. MOTIFI7 en est un exemple : 


POUR MOTIF17 ‘PROCÉDURE 
DÉFINIS «TRANSFORMATIONX [ [] [1] 
DÉFINIS «TRANSFORMATIONY [ [] [11 
MOTIF «HEX 17 ‘PROCEDURE 
EFFACE TRANSFORMATIONX 
EFFACE TRANSFORMATIONY 

FIN 


Après avoir vu les possibilités fondamentales, 
définissez le reste des motifs. 


Variante de logo 


Pour toutes les versions LCSI : 


Utiliser CS pour DESSINE. 

Utiliser OR pour AUMOINSUN. 

DONNEPOS suivi d’une liste est mis pour DONNEXY. 
Si a une syntaxe différente : 


SI :MOT = FIGURE [RÉSULTAT «R.FIGURE] 
TEXTE et DÉFINIS ne figurent pas parmi les 


primitives Atari LOGO, mais le manuel Atari 
indique une méthode pour les définir. 


# 


Beaucoup de jeux de type arcades utilisent un défilement d’arrière-plan 
pour donner l’impression de mouvement rapide. Voici une routine pour 
faire défiler l’arrière-plan horizontalement le long de l’écran du C64. 


La puce contrôleur vidéo (VIC) du Commodore 
peut déplacer l’écran du C64 d’une valeur pou- 
vant atteindre 8 pixels dans toutes les directions. 
Le déplacement horizontal est contrôlé par les 
3 bits inférieurs du registre VIC à l’emplacement 
53270 ($D016). Si l’on affecte à ces trois bits des 
valeurs de 7 à 0 successivement, on déplace pro- 
gressivement l’écran d’un pixel vers la gauche. 
En BASIC, nous utiliserions l’instruction POKE 
suivante : 


POKE 53270, (PEEK(53270) AND 248) + P 


où P est compris entre 0 et 7. 

En combinant cette possibilité avec une rou- 
tine en langage machine qui déplace toutes les 
données d’écran d’une cellule vers la gauche et 
introduit une nouvelle colonne de données sur le 
bord droit, nous pouvons produire un effet de 
défilement progressif. Afin que les données puis- 
sent entrer et sortir également progressivement 
de l’écran, la largeur d’écran du C64 doit être 
réduite à 38 colonnes au lieu de 40. Pour effec- 
tuer ce changement de mode, le bit 3 du registre 
de défilement horizontal doit être mis à zéro. En 
BASIC, on fait le POKE suivant : 


POKE 53270,PEEK(53270)AND247 


On peut remettre l’écran à l’état normal 
(40 colonnes) en mettant le bit 3 à 1. 


FENÊTRE ÉCRAN EN MÉMOIRE 


CHAQUE OCTET 

D'ÉCRANESTRECOPIÉ 

UNE CASE PLUS BAS 
\ 


L’organigramme détaille les différentes tâches 
à accomplir pour produire un défilement hori- 
zontal progressif. Il est important de noter que, 
si nous déplaçons ou insérons des données 
d’écran, nous devons aussi apporter les change- 
ments correspondants aux données couleurs. 

Les données d’écran sont normalement conte- 
nues dans 1 000 octets consécutifs à partir de 
l’emplacement 1024 ($0400) : les 40 premiers octets 
formant la rangée supérieure, les 40 suivants la 
deuxième rangée, et ainsi de suite. Pour que les 
données paraissent se déplacer d’une position à 
gauche, nous n’avons qu’à déplacer chaque octet 
de donnée dans l’octet en dessous de sa position 
initiale. Cette partie de la routine emploie les 
pointeurs de page zéro et l’adressage indirect 
pour déplacer chaque octet d’écran et donnée de 
couleur d’un octet plus bas en mémoire. 

Si nous appelons l’adresse de base de la zone 
écran SB, alors la dernière cellule de la rangée 
supérieure sera SB + 39, la dernière cellule de la 
seconde rangée SB +79, etc. Pour que les don- 
nées qui doivent défiler sur l’écran puissent être 
stockées en mémoire d’une manière analogue 
à l’écran réel — c’est-à-dire en paquets de 
1 000 octets — les données pour l’insertion à la 
droite de l’écran seront le 41°, 81°, etc., octets 
de la zone que nous avons réservée pour ces don- 
nées. Le diagramme suivant explicite cela : 


TROIS ÉCRANS 8 x 5 
CONTENUS EN MÉMOIRE 


UNE COLONNE DE 
MÉMOIRE EST 
INSÉRÉE 


Faites défiler votre écran 


Le défilement de motifs 
d'écran sur le VDU à 
partir de la mémoire 
implique trois stades 
principaux. Premièrement, 
chaque octet de la zone 
mémoire écran est abaissé 
d’une position. L'écran 
étant établi de telle sorte 
que les rangées soient 
mémorisées sous forme 
d'’octets successifs, cela 
fait apparaître un 
mouvement vers la 
gauche des caractères à 
l'écran, à l'exception de 
ceux qui apparaissent 
dans la colonne à 
l'extrême gauche. 

Chaque caractère de 
cette colonne paraît 

« s’enrouler » vers la 
colonne del'extrême droite. 
Le caractère en haut à 
gauche de l'écran disparaît 
pendant ce processus. 

La seconde phase implique 
la recopie de la colonne 
correspondante à partir 
de la mémoire écran 
dans la colonne de 
l'extrême droite. Cela 
étant, le registre de 
défilement de la puce 
VIC peut être manipulé 
plusieurs fois pour faire 
défiler un pixel à la fois 
dans la zone visible. 

(CI. Liz Dixon.) 


N.B. Le texte 
apparaissant ici en 
anglais est extrait de 
la fameuse chanson 
Clementine. 


COLONNE 
MEMOIRE 
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Étapes vers un défilement 
progressif 

Pour réaliser un défilement 
progressif, nous pouvons 
utiliser une aptitude 
particulière à la puce VIC 
du Commodore 64, qui 
possède des registres 
spéciaux de défilement 
permettant de déplacer 
l'écran visible de sa 
position normale 
relativement aux bords. 
On peut produire des 
pixels isolés en direction 
horizontale ou verticale. 
En combinant cet effet 
avec la copie de caractères 
en langage machine, nous 
pouvons produire un 
défilement progressif 

sur un écran réduit 

à 38 colonnes. 

(CI. Liz Dixon.) 
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Un pointeur est initialisé pour indiquer l’octet au 
début de la zone mémoire qui doit défiler sur 
l’écran. Une fois que la première colonne a défilé, 
alors le pointeur peut être incrémenté de 1 pour 
copier une seconde colonne sur le bord droit de 
l’écran, d’où il peut défiler vers la gauche. Après 
avoir réitéré le processus 40 fois, un écran com- 
plet de données a défilé. Le pointeur doit alors 
être incrémenté de 960 (1000-40) pour indiquer 
le début de l’écran suivant. 

Ce processus peut être répété pour la zone cor- 
respondante de données couleurs. Pour simpli- 
fier, nous pouvons faire en sorte que l’adresse 
de chaque octet de la table couleur ait un décalé 
constant pour l’adresse de l’octet correspondant 
dans la table de données écran. Le processus peut 
être réitéré pour autant d’écrans de données 
qu’on en a conçu et mis en mémoire. 

Afin d’utiliser la routine de défilement, plu- 
sieurs éléments d’information doivent passer 
avant l’appel. La routine doit connaître : 


1. L'adresse de début de la zone mémoire conte- 
nant les données écran à faire défiler. 

2. Le décalé des données couleurs corres- 
pondantes. 

3. Le nombre d’écrans de données à faire défiler. 
4. Une valeur retard, servant à ralentir l’opéra- 
tion de défilement progressif. 


Ces données doivent être POKées dans les empla- 
cements réservés dans le programme en langage 
machine. 


Programme basic d'appel 


18 REM 

20 REM 

30 REM ++ 22 
4@ REM + PROGR. BASIC D'APPEL 
S@ REM «+ DE ROUTINE DEFILEMENT 


95 DN-B:1REM POUR CASS DN=1 

188 IFA=BTHENA=1 : LORD" SCROLL. HEK° + DNs 1 
118 POKESS: D: POKESG, J21CLRIREM HAUT DE MEM INF 
115 GOSUB 1B@8:REM ETABLIT AFFICH SIMPLE 
128 

138 LMEM  =4S9664? 

148 HMEM "49665: 

158 LCOFF "49666: 

168 HCOFF "49667: 

170 NMSCR =49668: 

198 DELAY =49669: 

208 SCROLL =49670: 

210 : 

228 PRINT CHR#(147): REM EFFACE ECRAN 
238 INPUT “ADRESSE DEBUT DECIMAL*:SA 
248 HS=INT(SA/256) :1LS=BA-HS+256 

250 POKELMEM, LS: POKEHMEM: HS 

260 : 

278 INPUT “NOMBRE D'ECRANS"INS 

290 POKE NMSCR, NS ; 

300 : 

318 INPUT “DECALE DECIMAL POUR TABLE COULEUR" 106 
328 HO=INT(0S/256) :LO=0S-H0+256 

328 POKELCOFF, LO: POKEHCOFF » HO 

340 : 

350 INPUT"VALEUR RETARD < 296"1DV 


400 POKEST278, PEEK(33278) DRB 


Le programme charge le code machine en 
mémoire et demande des renseignements via des 
instructions INPUT. Puis il met ces informations 
sous forme d’octets lo et hi, et les POKE dans les 
espaces de stockage alloués au début du pro- 
gramme en langage machine. La routine en lan- 
gage machine est alors appelée. 


Les adresses de début, décalé et nombre 
d’écrans doivent être spécifiés, bien que les résul- 
tats ne soient pas très significatifs si l’on ne met 
pas de dessins d’écran dans une zone mémoire 
spécifiée. On peut tester le programme en char- 
geant et exécutant le court programme BASIC qui 
établit deux simples écrans de données commen- 
çant à l’emplacement 819. Le décalé à la zone 
données couleurs est 3 000 octets. Pour faire défi- 
ler cette zone données sur l’écran, l’information 
suivante doit être donnée en réponse aux sugges- 
tions du programme d’appel : 


1. Adresse de début décimal ........ 


Chargeur basic 


19 REM 

15 REM ++ CHARGEUR BASIC POUR ++ 

20 REM ++ ROUTINE DE DEFILEMENT + 
HORIZONTAL L.) 


70 READ A:POKEI, A 

80 CC-CC+rA 

90 NEXT 

92 RERD CS:1F CS<>CC THEN PRINT“CHECKSUM ERROR":STOP 
100 DATA17S, 22, 208. 41, 247, 141, 22, 208 
118 DATAI 74, 4, 194, 160, 48, 138, 72, 152, 72 
128 DATA17Z, 22, 288. 41, 248, 24, 185, 7, 181 
138 DATAZ2, 208, 169, 9, 133, 251, 169, 4, 133 
148 DATA292, 169, 8, 133, 293, 169, 216, 133 
158 DATA254, 162, 3. 160. 1. 177, 251, 136 
168 DATA1AS, 251.208, 177; 253, 136, 185 
178 DATAZSS, 200, 206, 208, 241,230, 252 
188 DATA230, 254, 177, 251, 198, 252, 136 
190 DATA145, 251, 208. 177, 253, 198, 254 
200 DATALSE, 145. 253, 238, 252, 238, 254 
218 DATA282, 208, 215, 168, 1, 177,251; 136 
228 DATA14S, 251, 200. 177, 293, 136, 145 
238 DATA2SS, 200. 208. 192, 232, 144, 2359 
248 DATALTS: @ 194, 133, 253, 1734 1, 194 
250 DATALSS, 254, 169, 39, 133, 251, 169, 4 
260 DATALSS, 252, 32, 241, 194, 173.0, 194 
278 DATAZ4, 189, 2, 194, 133, 253, 173, 1, 194 
286 DATA19S, 3, 194, 133, 254. 169, 39, 133 
29% DATA2S1, 169, 216, 133, 252, 32, 241, 194 
308 DATALE2, 6. 173, 22, 208, 41. 248, 141, 22 
710 DATA2ES, 110, 24, 189, 22, 208, 141,22 
320 DATA208, 172,5, 194, 136, 208, 253, 202 
336 DATAIE, 231: 173, @, 194, 24, 185, 1, 141 
340 DATRE. 136. 173, 1, 196. 185, 8, 141,1 
358 DATA1SA, 184, 168, 184, 178, 136, 240, 3 
368 DATA7E, 19, 194, 173, @, 194, 24, 105, 192 
370 DATALAL, @, 194, 173, 1, 194, 185, 3, 141 
380 DATA1, 154, 202, 249, 3, 76, 17, 194,96 
390 DATA162, 25, 168, ©, 177, 253, 145, 251 
48e DATA22, 240, 29, 185, 251; 24, 105, 40 
418 DATALSS, 251, 165, 252, 185, D, 133, 252 
428 DATAIES, 253, 24, 185, 48, 133, 253, 165 
438 DATA2S4, 183, @, 133, 254, 76, 245. 194 
448 DATASS 

458 DATA4G227 : REMeCHECKSUMe 


Routine établissement d'affichage 


1000 REM ses ETABLIT AFFICHAGE mms 
1018 CL=3000:REM DECALE TABLE COULEUR 
1020 SS=B192:REM DEBUT DE TABLE AFFICHAGE 
1830 FORI=SS TO 58+479 

1948 POKEI. 1:1REM CODE ECRAN POUR "A" 
1058 POKEI: 1+CL, 1:1REM BLANC 

1060 POKE1+480, Z:REM CODE ECRAN POUR 8" 
1878 POKEI+CL+488, 14:REM BLEU CLAIR 
1088 NEXT 

1885 FORI=SS+960T08+299 

1890 POKEI, 32REM CODE ECRAN POUR *C' 
1188 POKEI+CL, 3:REM BLEU FONCE 

1118 NEXT 

1939 : 

2020 SS=9192:REM DEBUT D'ECRAN SUIVANT 
2030 FORI=SS TO 5S+479 

2048 POKEI, S:REM CODE ECRAN POUR *C' 
2850 POKEI+CL, S:REM VERT 

2060 POKEI+480, 4:1REM CODE ECRAN POUR "D" 
2078 POKEI+CL+480, G:REM NOIR 

2088 NEXT 

2885 FORI=88+9687058+999 

2090 POKEI,S:REM CODE ECRAN POUR ‘E* 
2188 POKEI+CL. 21REM ROUGE 

2118 NEXT 


SCRPTR+1 *INC HIBYTES ADC 
COLPTR+1 :0F @ PAGE PTRS STA MEMHI 

RSR RSR RSR RSS SSSR RSR SSSR CSCRPTR), Y 3 
RSR RSR RSR RSR RS RS RRRSSSEE SCRPTR+1 $++++ CHECK FOR END OF MEMORY AREA ++++ 
++ L ++ : 
5++ Défilement horizontal (SCRPTR), Y: COPY OVER PAGE PLA 
++ pour CBM 64 ++ GET X,Y REGS BACK 
++ É ++ CCOLPTR), Y 
RAA ER COLPTR+1 :0FF STACK 
BARRES 
ü CCOLPTR), Y 
SCRPTR=$FE 50 PAGE SCRPTR+1 INC @ PAGE PTRS 
COLPTR=#$FD 3COPY POINTERS COLPTR+1 AGAIN 
ü 
MEMPTR=$FD 30 PAGE PTR TO MEMORY AGAIN 
SCRLRG=$D016 SHORIZ SCROLL REGISTER 3 ADD 1200-40 
SCRNLO=$00 3SCREEN START LOBYTE 5++ DO EXTRA BYTES ++ :TO MEMORY POINTER 
SCRNHI=$04 F3SCREEN START HIBYTE LDY ##01 
COLRLO=$00 3COLOUR START LOBYTE ANTHER 
COLRHI=#$D8 *COLOUR START HIBYTE LDA (CSCRPTR), Y 
BLOCKS=#$05 33#256 BYTE BLOCKS DEY 
EXTRA =$€8 : FEXTRA BYTES TO 1000 STA (SCRPTR), Y 
NMCOLS=#$28 NO OF COLUMNS INY 
NMROWS=$19 NO OF ROWS LDA (COLPTR),Y 
3 DEY 
+=$C200 CCOLPTR) , Y 3 
0 5++++ COPY EVERY 40TH BYTE S/R ++++ 
MEMLO +=# +1 START OF MEMORY ; 
MEMHI +=w+]l TO BE SCROLLED REXTRA CoPY4g 
COFFLO #=w+1 30FFSET TO COLOUR MAP ANTHER SIF YCEXTRA REPEAT LDX #NMROWS 
COFFHI #=w+1 $ LDY ##20 
NMSCRN  #=%+1 NUMBER OF SCREENS ++++ INSERT RIGHT COLUMN OF SCREEN ++++ 
DELAY +=] #DELAY LOOP VALUE 3 CMEMPTR) , Y 
3 LDA MEMLO CSCRPTR), Y 
i++++ SET 38 COLUMN MODE ++++ STA MEMPTR 
: LDA MEMHI 5SET UP @ PAGE FINISH EVERY ROW DONE? 

LDA SCRLRG STA MEMPTR+1 3PTRS TO MEMORY 

AND ##$F7 LDA #NMCOLS-1 SCRPTR 

STA SCRLRG STA SCRPTR SET UP @ PAGE 
: LDA #SCRNHI *PTRS TO SCREEN #$NMCOLS INC PTRS EY 40 


5++++ SET 1ST SCROLL POSITION ++++ STA SCRPTR+1 SCRPTR 
JSR COPY40 COPY COLUMN SCRPTR+1 


LDX NMSCRN 3 #s00 
' 5++++ INSERT RIGHT COLUMN OF COLOUR ++++ SCRPTR+1 


LDY #NMCOLS ; 
LDA MEMLO MEMPTR 
cLC 
3PUSH X, Y REGS ADC COFFLO *ADD OFFSET TO #NMCOLS 
*ONTO STACK STA MEMPTR COLOUR MAP MEMPTR 
LDA MENHI SAND SET @ PAGE MEMPTR+1 
ADC COFFHI 3PTRS #50 
LDA SCRLRG STA MEMPTR+1 MEMPTR+L 
#sFe LDA #NMCOLS-1 3SET UP @ PAGE REPEAT 
STA SCRPTR *PTRS TO COLOUR 
#507 LDA #COLRHI RAM 
SCRLRG STA SCRPTR+1 
=: JSR COPY4Q *DO COPY 
5++++ COPY SCRN & COLR ONE LEFT ++++ 3 
; 5++++ SCROLL POSITIONS 6 TO © ++++ 
LDA #SCRNLO 3 
STA SCRPTR 3SET UP @ PAGE LDX ##0E 
LDA #SCRNHI 
STA SCRPTR+1 :POINTERS FOR LDA SCRLRG 
LDA #COLRLO AND ##FE 
STA COLPTR COPY STA SCRLRG 
LDA #COLRHI TXA 
STA COLPTR+1 CLC 
ADC SCRLRG 


LDX #BLOCKS STA SCRLRG 


##01 DELAY 3COUNT DOWN 


CSCRPTR) ; Y 3DELAY VALUE 
MORE2 
CSCRPTR) , Y 
MORE 1 
5++++ INCREMENT MEMORY POINTER ++++ 
3 


CCOLPTR), Y 


(COLPTR), Y 
LDA MEMLO 


LC 

Se ADC #1 
. STA 
++ COPY OVER PAGE BOUNDARY ++ LDA 


Livres pour débuter 


SE 


Voiciune sélection delivres pour vousinitier à ces étranges et merveilleuses 
machines que sont les micro-ordinateurs. Ils vous feront entrer dans 
le cercle des amateurs éclairés, puis des passionnés de micro-informatique. 


sac 


PE 
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